package com.ruoyi.shop.modules.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.ruoyi.shop.modules.domain.ProductOperLog;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;

import java.util.List;

/**
 * 用户商品浏览、搜索历史Mapper接口
 *
 * @author zjc
 * @date 2024-07-02
 */
public interface ProductOperLogMapper extends BaseMapper<ProductOperLog>
{
    /**
     * 查询用户商品浏览、搜索历史
     *
     * @param id 用户商品浏览、搜索历史主键
     * @return 用户商品浏览、搜索历史
     */
    public ProductOperLog selectProductOperLogById(Long id);

    /**
     * 查询用户商品浏览、搜索历史列表
     *
     * @param productOperLog 用户商品浏览、搜索历史
     * @return 用户商品浏览、搜索历史集合
     */
    public List<ProductOperLog> selectProductOperLogList(ProductOperLog productOperLog);

    /**
     * 新增用户商品浏览、搜索历史
     *
     * @param productOperLog 用户商品浏览、搜索历史
     * @return 结果
     */
    public int insertProductOperLog(ProductOperLog productOperLog);

    /**
     * 修改用户商品浏览、搜索历史
     *
     * @param productOperLog 用户商品浏览、搜索历史
     * @return 结果
     */
    public int updateProductOperLog(ProductOperLog productOperLog);

    /**
     * 删除用户商品浏览、搜索历史
     *
     * @param id 用户商品浏览、搜索历史主键
     * @return 结果
     */
    public int deleteProductOperLogById(Long id);

    /**
     * 批量删除用户商品浏览、搜索历史
     *
     * @param ids 需要删除的数据主键集合
     * @return 结果
     */
    public int deleteProductOperLogByIds(Long[] ids);

    @Select("select product_id from prd_product_oper_log where user_id = #{userId} order by create_time desc limit 8")
    List<Long> selectByUserId(@Param("userId") Long userId);
}